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1  A,  InCruikicLioii 


We  study  in  this  paper  a  problem  concerning  the  sclieciuling  of  a  set 
of  jobs  on  a  single  processor  computer  system.  In  our  model,  a  job 
consists  of  a  periodic  stirainof  identical  rofiuests.  That  is,  a  job 

demands  periodically  C^  units  of  computation  time  in  every  T;  units 
of  time.  We  siiall  use  Ji  ,  J;  ,  ...,  to  denote  the  jobs,  Ti  ,  Tj  , 

to  denote  the  request  periods,  and  ,  C,  ,  .  .  .  ,  to  denote  the  computation 
times.  (Tliiouglcu  t  our  discussion,  we  sliall  assume  for 

convenience  in  notations).  That  is,  a  job  J\  is  completely  cliarac  ter  i  7.eil  ^ 
by  an  ordered  pair  of  numbers  (C.,  "l£)  • 

by  scheduling  a  sot  of  jobs  we  mean  to  detcnv.inc,  at  any  time  instant,  Che 
particular  rcquo.st  to  v.hich  the  processor  should  be  devoted.  In  our  model, 
the  criterion  of  scheduling  is  to  satisfy  each  request  prior  to  its 
deadline,  wi-.ic’n  is  ti'.e  arrival  time  of  the  j’.e.'ct  request  of  the  same  job. 

A  set  of  jobs  is  said  to  be  scheJulable  by  a  certain  scheduling 
algoritlum  if  such  a  criterion  can  bo  met.  Throughout  our  dicussion,  we 
assume  that  the  prccr.'.pt ivo  sci'.oduling  discipline  is  employed.  That 
is,  the  execution  of  a  job  can  bo  i.ntcrrupted  by  the  execution  of  another 
job.  .  Thus,  a  request  of  C.  units  of  computation  ti.me  can  be  satisfied 

by  one  or  more  quanta  of  tine  which  sun  to  C; . 

* 

A  vcll-knova  schodul  ing  al.corith.m  for  our  mcdel  is  Che  earliest 
deadline  first  scl.cduiing  algorictim  (  !,  2,  3!.  In  this  case,  priorities 
are  assigned  to  tiic  requests  according  to  their  deadlines,  with  highest 
priority  assigned  to  th.c  request  with  the  oarlic.se  deadline.  The 
arrival  of  a  request  wi:!'.  a  h.iglior  priority  always  preempts  tlic  execution 
of  a  request  with  a  lover  priority.  The  cnrliist  deadline  first  scheduling 
algor;  th:':  lias  boL".;  sh.own  to  be  optimu.m  in  t;;e  .son.so  that  if  a  .set  of 
jobs  is  schicdu la;i  1  c  by  any  scheduling  algorithm  c!icn  the  set  is  also 
schedulablo  bv  tl;e  e.arliosc  deadline  first  scheduling  algoricliin. 


Anotlier  nclicduling  algorithm  which  was  studied  in  [3]  in  Che 
rate  rur.iT.ouio  .neiicuu]  i  ng  .a  1  gor  i  dim.  In  tliis  case,  iiigher  priority  is 
assignovi  to  a  request  v;itii  .shorter  rcquo.st  period.  Thus,  for  example, 
the  requests  of  tin?  job  with  t’ne  siiortost  request  period  will  .nlv.'ays 
proeaipc  any  reepa  st  of  another  job.  This  algnri  tiiir.  i.s  inferior  to  the 
earliest  deadline  tir.nt  ain.orithm  in  the  scn.se  that  there  are  sots 
of  jolis  uiiir.it  arc  sr  i.edu  1  .i!i !  o  by  the  c.u'liesc  deadline  fir.st  algoritltm 


while  nnc  sclieilul.nhlc  by  Llie  rate  mcnoLonic  algorillim.  However,  the  rate 
monotonic  alf.oritlim  is  simpler  to  implement ,  r  the  rmorc ,  the  simplicity  of 
this  alfjorithm  enables  us  to  estimate  the  slack  time  of  a  request,  which 
is  the  subject  of  this  paper.  It  is  often  the  case  that  instead  of 
simply  meeting  the  deadline  of  cacli  request,  we  might  wish  to  satisfy 
each  request  ahead  of  its  deadline  so  that  there  will  be  a  time 
span  between  c!io  completion  of  the  execution  of  a  request  and  the 
deadline.  We  cail  suc!i  a  time  span  the  s  1  a  <:  Ic  t  inie  of  tlie  request. 

rtC  summarise  here  some  of  the  results  in  [3]  that  will  be  useful 

in  our  study,  ’-.'o  use  ui  ,  u:  ,  denote  the  ratios  C|  /Ti  ,  Cj /Tj 

C  /T  .  We  use  u  to  denote  the  sum  -  C./T.,  u  is  rofenred  to  as  the 

n  n  .  _  j  1  1 

u t  i  1  i  aa  r  1  on  f a e  t o r  of  tl’.e  set  of  job;:  Ji  ,  J:  ,  .  .  .  A  set  of  jobs  is  said  to 
full II i  ’■  i  .te  cl'.e  processor  with  respect  to  a  particular  sclicduling 
algoriti-.rn  if  ti.e  sot  of  jobs  is  sci-.ouul.iii  e  by  the  algorithm  win  i  e  increasing 
the  computation  ti.me  of  any  of  the  jobs  will  cause  the  set  to  become 
unscliedulaiile .  (Mote  tliac  the  lotion  of  full  utilication  is  defined  with 
respect  to  a  particular  schcculing  algoritlmi.  For  example,  the  set  of 


jobs  {Ji 


,  2),  J;  »  (2,5)}  fully  utilizes  the  processor  with 


respect  to  the  rate  monotonic  scheduling  alp.orich.m.  However,  this  set 
docs  not  fully  utilize  the  processor  wicli  respect  to  the  earliest 
dcaline  first  schedul  ir.'.*,  aigori  tl.m)  .  Proofs  of  the  follov.’ing  theorems 
can  ho  found  ia  [  3!  : 


Ti.ooro-i  :  :  A  sot  of  n  jobs  witl;  a  utilization  factor  less 

►  i,...,  -1........  ...v,  .a..  1  ,1. 1  ,  w.. 


-  1)  is  alwavs  sch.'dulablc  bv  the  rate  monotonic 


sciu ^.11 1  i. no,  a.gor: 


Th'^o.-y:!!  2  :  A  set  of  n  jobs  with  a  utilization  factor  less  than-’ 
n(2‘ ' I)  does  r.ot  fully  utilize  tlic  processor  with  respect 
to  the  latc  monoti'nic  scheduling  algoritlim.  Moreover,  there  -d 
exists  a  set  of  n  jobs  with  a  utilization  factor  e^u.al  to  . 


n(2  ' -  I)  that  fully  utilizes  tlio  processor. 


'1^ 
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while  nou  schcclulable  by  the  rate  monotonic  algorithm.  However,  the  rate 

mouotonic  algorithm  is  simpler  to  implement. l\irthormore,  the  simplicity  of 

this  algorithm  enables  us  to  estimate  tlie  slack  time  of  a  request,  which  ,, 

is  the  subject  of  this  paper.  It  is  often  the  case  that  instead  of 

simply  meeting  the  deadline  of  each  request,  we  might  wish  to  satisfy 

each  request  ahead  of  its  deadline  so  that  there  will  be  a  time 

span  between  the  completion  of  the  execution  of  a  request  and  the 

deadline.  We  call  such  a  time  span  Cl>c  slack  time  of  the  request. 

I 

We  summarize  here  some  of  the  results  in  (3)  that  will  be  useful 

in  our  study.  We  use  uj  ,  U2  ,  to  denote  the  ratios  Ci /Tj  ,  C2/TJ,..., 

C  /T  .  We  use  u  to  denote  the  sum  C./T..  u  is  refeircd  to  as  the 
n  n  .^1  1.  1 

utilization  factor  of  the  set  of  jobs  Ji  ,  J2,...,J^.  A  set  of  jobs  is  said  to 

fully  utilize  the  processor  with  respect  to  a  particular  scheduling 

algorithm  if  the  sot  of  jobs  is  schcdulalil  e  by  the  algorithm  while  increasing  » 

the  cimpuCation  time  of  any  of  the  jobs  will  cause  the  set  to  become 

unschedulable. (Note  that  the mtion  of  full  utilization  is  defined  with 

respect  to  a  particular  scheduling  algoritlmi.  For  example,  the  sot  of 

jobs  {Ji  »  (!,  2),  J:  »  (2,5)}  fully  utili  zes  the  processor  with 

respect  to  the  rate  monotonic  scheduling  algorithm.  However,  this  set 

does  not  fully  utilize  the  processor  with  rcsocct  to  the  earliest  ! 

dealinc  first  scheduling  algoritlan).  Proofs  of  the  following  theorems 

can  bo  found  in  (  3l  ; 


Theorem  1  :  A  set  of  n  jobs  with  a  utilization  factor  less 
than  n(2'^''-  1)  is  always  schedulable  by  th.e  rate  monotonic 
scheduling  algorithm. 


Theoroiii  2  ;  A  sot  of  n  jobs  with  a  utilization  factor  less  than-* 
n(2‘ 1)  does  not  fully  utilize  the  processor  with  respect  ^ 

to  tlie  rate  monotonic  scheduling  algorithm.  Moreover,  there  'd  r] 
exists  a  set  of  n  jobs  \»'i  th  a  utilization  factor  ^ual  to  . 

n(2'  -  1)  that  fully  utilizes  the  processor.  Bv _  i 
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2.  A  FundamenCal  theorem. 


Suppose  that  Jj  ,  Ji ,  are  to  be  scheduled  by  the  rate 

monotoalc  scheduling  algorithm.  Wc  shall  assume  that  the  first  request  of 
all  these  jobs  arrive  at  t»0.  (As  a  matter  of  fact,  Theorem  3  below 
shows  that  such  an  assumption  covers  the  vorst  possible  case).  We  define 
the  availability  function  f(t)  to  be  ; 


r(t)- 


I  if  the  processor  is  occupied  at  t 

0  if  the  processor  is  not  occupied  at  t 


For  any  L  5nd  T,  the  integral 
J  ^  ^  /  (t)dt 

gives  tho  total  units  o£  time  that  the  processor  is  not  occupied 
between  A  and  L  *  ^  sequence  of  demands  (not  necessarily  periodic) 

within  the  time  interval  (O,  tj^l  can  be  denoted 

D  ■  (di  ,  (o,  til),  (dj ,  [ti,  tjl),  •••,  (dj^  ’  ^  —  I  *  ^ 

to  mean  that  di  units  of  computation  time  is  demanded  within  the  time 
interval  (O,  til,  d:  units  of  computation  time  is  demanded  within  the 
time  interval  (  ti  ,  t:],  and  so  on.  We  shall  use  0^  to  denote  the 
sequence  of  demands. 

»  (di  ,  I A ,  tj  a1  ) ,  (dj ,  I  ti  ♦  A ,  tj  a)  ) ,  . . . , 

^  '^k-l  *  ^k  *  ^ 

which  is  D  delayed  by  A.  Given  an  availability  function?*  vt)  and  a 
sequence  of  demands  D  within  the  time  interval  [O,  tj^l  ,  and  assumed 
that  the  demands  in  1)  have  priorities  lower  than  all  the  requests 
of  the  jobs  Jj  ,  J:  ,  ....  then  the  demands  in  1)  v>,’iU  take  up  the 
first  di  units  of  time  within  the  time  interval  (O,  til  ‘in  /  (t), 
and  so  on.  (Assume  that  /^t)  can  satisfy  the  demands  in  D). 

We  shall  use 

/(t)  -  D(t) 

to  denote  the  available  time  that  remains  after  all  the  demands  in  D 
are  satisfied.  (This  is  a  slight  abuse  of  notation,  since  straightly 
speaking  a  sequence  of  demands  is  not  a  function  of  time. 

Rather,  !)  induces  a  corresponding  l)(t)  for  a  given  f{l) ,  and  will 
induce  a  different  D(t)  tor  a  different  /(t).)The  following  Lemmas  are 


2.  A  Kunclamcntnl  theorem. 


Suppose  that  Jj  ,  Jj ,  are  to  be  scheduled  by  the  rate 

monotonic  scheduling  algorithm.  We  shall  assume  that  the  first  request  of 
all  these  jobs  arrive  at  t»0.  (As  a  matter  of  fact,  Theorem  3  below 
shows  that  such  an  assumption  covers  the  worst  possible  case).  We  define 
the  availability  function  f(t)  to  be  : 


r(t)- 


1  if  the  processor  is  occupied  at  t 

0  if  the  processor  is  not  occupied  at  t 


For  any  L  Snd  T,  the  integral 

gives  the  total  units  ot  time  that  the  processor  is  not  occupied 
between  A  and  A  .  A  sequence  of  demands  (not  necessarily  periodic) 
within  the  time  interval  (O,  t^l  can  be  denoted 

D  "  (^1  •  (0|  t{)),  (di  ,(ti,  tj)),  ...,  I  _  j  •  ) 

to  mean  that  di  units  of  computation  time  is  demanded  within  the  time 
interval  (O,  ti  ] ,  d;  units  of  computation  time  is  demanded  within  the 
time  interval  (  ti  ,  t:  ] ,  and  so  on.  We  shall  use  to  denote  the 
sequence  of  demands. 

■  (di  ,  (  A ,  ti  +  A1  ) ,  (dj  ,  (  ti  ♦  A ,  tj  ♦  a1  ) . 

^  ^k-l  'k 

which  is  D  delayed  by  A.  Given  an  availability  function?'  vt)  and  a 
sequence  of  demands  D  within  the  time  interval  (O,  tj^l  ,  and  assumed 
that  the  demands  in  U  have  priorities  lower  all  the  requests 

of  the  jobs  Ji  ,  J:  ,  ...,  then  the  demands  in  1)  will  take  up  the 
first  di  units  of  time  within  the  time  interval  lO,  til  in/  (t), 
and  so  on.  (Assume  that  /(t)  can  satisfy  the  demands  in  D). 

We  shall  use 

fit)  -  D(t) 

to  denote  the  available  time  that  remains  after  all  the  demands  in  D 
are  saCis.‘'iod.  (This  is  a  slight  abuse  of  notation,  since  straightly 
speaking  a  sequence  of  demands  is  not  a  function  of  time. 

Rather,  !)  induces  a  corresponding  l)(t)  for  a  given  /(t),  and  will 
induce  a  different  u(t)  for  .n  different  /(t) .)  The  following  l.einmas  are 
obvious  : 


Lcmnm  1 ;  For  any  f  (t)  and  any  U  within  the  time  interval  [O,  t1  ,  if 


f  +  T 


/(t)dt  S 


f  Aj  +  T 

J  A, 


T  A.  T  A, 

Ja,  l/(t)  -  D'^‘(t)ldt  S  (/(t)  -  D^’(t)ldt 

l.ciiima  2  ;  Lo  t 

"  (di  (  I  0|  t  •) )  •  (dj  ,  (tj,  t}|^i<<««  ^ 

be  a  sequence  of  demands.  Let 

E  ■  (0,  {  0,  6) ) ,  (di  ,  (  d ,  ti  +  dl ) ,  (dj ,  (  tj  +  d,  tj  +  d] ; , 

. . .  (dj,,  I  U|^_|  +  d,  tj^  ♦d  ! ) 

That  is,  E  is  the  sequence  of  demands  in  D  delayed  by  d  mits  of  tine. 

Then,  for  any  T 

rA  +  T  .  *  T  . 

^  (/(t)  -  D''(t)ldt  S  ^  l/(t)  -  E^(t))dt 

We  prove  now  a  fundamental  theorem  v;hich  will  bo  needed  in  our  later 
discussion  : 


Theorem  3  :  For  any  set  of  n  jobs  J-’ ,  'scheduled  by  the 

race  monotonic  schcdnlins  algorithm,  we  have 

[t  ,A  ♦  t 

Jo  /(t)dc  S  J  /(t)dt 

for  any  A  and  x  . 

Proof  ;  The  theorem  is  proved  by  induction  on  n.  As  the  basis  of 
induction,  we  note  that  for  n  *  i,  /  (t)  is  a  periodic  function  of  period 
Tj  so  that  /  (t)  =0  for  the  fir.sc  Ci  units  of  time  and  /  (t)  »  1  for  the 
next  Ti  -  Cl  units  of  time  in  each  period.  Clearly, 

)‘  /(c)dt  <  f  /(t)dc 

^0  A 

To  carry  out  the  induction  step,  we  a.ssume  that  the  theorem  is  true 
when^  ((t)  is  Che  availability  function  after  n-1  jobs  have  been  scl.cdulcd. 
Let  /  (t)  denote  the  .ivai  lahi  1  i  ty  fvmction  after  n  jobs  have  been  scheduled. 


According  Co  Lcnuna  ! 

r  (Xt)  -  D(r.)ldt  £  f  '  l/(t)  -  D'5(t)Jdt 

JQ  '  ifi 


f6  +  r 


That  is. 


ft 

/  (t)dt  S 

0 


•6 

•6 


T  ^ 

f (t)dt 


(2) 


Combining  (O  and  (2),  we  obtain 

f  A  +  T  - 

It  S  /(t)dt 

0  U 


f  ;(t)dt  s  f 

J  n  h 


Case  2  ; 

A  A 

/  (t)  0  £ur6  s  .  S  A.  That  /  (t)  0  implies  the  demand  within 

the  time  interval  ( rT  ,  (r+l)T  ]  is  satisfied  at  crprior  to  C  ■  A. 

n  n 

Tims,  within  the  time  interval  (A,  (r  +  l)T  1,  fit)  •  fit), 

n 

Let  X  denote  (r+l)T^-A.  Let 

E  -  (0,  (0,  Xli,  (C^.lT^^  X,  2Tj^+Xl  ) . 

(C^,  {kT^+  X-,(k+l)Tj^*X  1) 

That  is,  E  is  D  delayed  by  X.  Thus,  we  can  write 
fA  ♦  T  •  CA  +  X  . 

If  it)  -  E  '^(t)rdt 


/  (t)dt  ■ 


(3) 


According  to  Lemma  2 
rA+  X 


X  rA  X  . 

l/(t)-  D-'(t)ldt  i  l/(t)-E'^(t)ldt  (4) 

^A  ^A 

However,  according  to  Lemma  I  and  the  induction  hypothesis 

fA  +  X 


f  /(t)dt 


J, 


iy(t)-i/(t))dt  (5) 


Combining  (3),  (4),  and  (5),  v/e  obtain 

rA  +  X 


r 

'0 


/(t)dt 


l/(t)  -  E“(t)]dt  = 


A  +  X^ 

/(t)dt 

A 


r 


W 


3.  Estimation  of  slack  Time. 

We  show  in  this  section  lower  bounds  on  the  slack  time  of  a 
request.  Theorem  4  and  5  in  the  followings  will  be  proved  by  induction 
on  the  number  of  jobs.  We  show  first  a  lemma  which  be  used  as  Che  basis 
of  induction,  in  the  proofs  of  Theorems  4  and  5. 

Lomm.n  3  :  Let  Ji  and  be  two  jobs  scheduled  according  to  the  rate 

monotonic  scheduling  aigoritlmi,  with  u<  2(2*/2“l).  For  an  arbitrary  request  of 
J: ,  lee  q  denote  the  size  of  the  last  qu.intum  of  time  allocated  to  Che 

request  and  s  denote  the  length  of  the  slack  time.  Then  s  h  0.  207q 
Proof  :  We  examine  two  cases  : 

Case  1  :  The  execution  of  the  last  quantum  of  the  request  begins  at  no  more 
than  Tt  units  of  time  after  the  arrival  of  the  request,  as  illustrated 
in  Fig.  2(a) . 


Fig.  2. 

In  this  case,  since  a  STi  ,  during  this  a  units  of  time  atmost 

C|  units  of  computation  time  was  devoted  to  Ji  .  Thus  we  have 

s  ST:  (Cl  +  C: )  =  Ti  (  i- 


^  ^')j 

Xl  l2 
»  T:  (1-  u) 

C,(>^) 

.  q  (J^)  . 


/ Us  ^  / *“  0.83^ 

l[—~)  >  q  (---.--)  =0.: 


Case  ?■  :  Tlic  execution  of  the  last  quantum  of  the  request  bogiiu  at  more 
than  Ti  units  of  time  after  the  arrival  of  the  request,  as  illustrated 
in  Fig.  2(b). 


Let  b  denote  C  -  q.  We  have 


Cl  .Cl  ,  b+q^ 

Ti  Ti  ‘  a+q+s 


b+q«(a+q+s)  (u-ui ) 
or 

s(u-ui)  ■  q(|-u+ui)  +  b-  a(u-ui)  (6) 

Consider  a  job  that  has  a  request  period  equal  to  a  and  computation 
time  equal  to  b.  Suppose  wc  want  to  suhcdulc  Ll\u  two  jobs  (C|  ,  Ti)(b,a) 

t 

according  to  the  rate  monotonic  scheduling  algorithm.  According  to  Fig.  2(b}» 
and  Theorem  3,  after  Ji  was  scheduled  the  total  processor  time  avail.ible  for 
Ji  in  the  time  interval  (  0,  a]  is  less  than  or  equal  Co  b.  Consequently, 
cither  the  set  { (Ci ,  Ti ) ,  (b,  a)}  fully  utilizes  the  processor  or  Che  set 
is  not  schcdulable  at  all.  In  cither  case,  according  to  Theorems  I  and  2, 


we  have  : 


That  is 


u,  ♦  -  i  2(2‘^^-l)>  u 


b  -  a(u  -  ui )  >0 
Consequently,  (6)  yields 

sfu-ui)s:q(l-u  +  ui) 
s  a  q  (-i-—)  b  0.207q 


Vo  now  have  : 

Thcorom  4  ;  Let  Jj,  Ji,...,  be  n  jobs  scheduled  according  to  the  rate 
monotonic  scheduling  algorithm.  Let  q  denote  the  length  of  the  last  quantum 
of  time  allocated  to  the  first  request.  If  u  <n  (2  ^”-1)  then  the  slack 
time  of  any  request,  is  larger  than  or  equal  to  0.207  q. 

Proof  ;  According  to  Theorem  3,  the  slack  time  of  the  first 
request  is  l'’s.s  than  or  equal  to  the  slack  time  of  any  request.  Thus, 
it  is  sufficient  to  prove  rhat  the  slack  time  of  the  first  request  is 
larger  than  or  equal  to  0.207  q. 

The  theorem  is  proved  by  induction  on  n.  Lemma  3  provides  the  basis 
of  induction.  As  to  the  induction  step,  we  assume  that  the  theorem  is  true 
for  n  -1  jobs.  Let  us  use  q  and  s  to  denote  the  length  of  the  last 
quantum  of  time  allocated  to  Llio  first  request  of  and  the  slack  time  of 
this  request.  We  consider  two  cases  : 


Case  I  :  llic  cxccutiuu  of  the  last  quantum  ul  time  allocatuU  Ct>  icqutut 
begins  at  no  later  than  t  «  T^_j  as  illustrated  in  Fig. 3(a), 


Fig. 3. 

Consider  the  set  of  n  -  |  jobs  (Ci  ,  Ti),  (Cj ,  Tj),  .... 

(C  ,  +  C  ,  T  ).  According  to  the  diagram  in  Fig. 3(a)  and  Theorem  3, 

n“  I  n  n 

this  set  of  n  *■  I  jobs  is  schcdulable  by  the  rate  monotonic  scheduling 
algoritlOT.  Furthermore,  the  first  request  of  the  job  T^^)  will 

occupy  the  processor  during  the  time  intervals  in  which  the  first 
request  of  and  the  first  request  of  occupy  the  processor  when 
the  jobs  Ji ,  J: ,  ....  were  scheduled.  Let  q*  and  s'  denote  the  length  of 
the  last  quantum  of  time  allocated  and  the  slack  time  of  the  first  request 
of  the  job  C^»  T^) .  Then  according  to  the  induction  hypothesis 

s'  >  0.207q' 

Howerver,  since 

s'  «  s  and  q'5  q 

wo  have 

s  S  0.207  q 


Case  2  ;  The  execution  of  the  last  quantum  of  time  allocated  to  the 

request  begins  at  later  than  t  »  as  illustrated  in  the  diagram  in 

Fig.  3(b).  Let  b  denote  C  -  q.  We  have 

n 


.i  u.  +  TT 


n-l  ,  , 

V  .  b  +  q 
.2.  u .  +  - *- 


a  +  q  +  s 


which  can  be  written  as 

n- 1  *  n  -  1 

s(u-.-u.)-q(l“  u  +  u.)  +  h-  a(vj-.-  u.) 

1=1  1  ‘  1=1  1  1=  1  1 


Consider  the  n  jobs  (Ci ,  Ti),  (Ci ,  T: ) , 


According  to  the  diagram  in  Fig. 3(b),  this  set  o£  jobs  fully  utilizes 
the  processor  with  respect  to  the  rate  monotonic  scheduling  algorithm. 

(The  processor  was  never  left  idle  within  the  time  interval  { 0,  a]. 

Because  if  this  was  not  the  case,  the  first  request  of  will  be  completed 
earlier) .  It  follows  that 

K 

.S  u.  +  -  >  u 
i-*i  i  a 


or 


n-j 

b  -  a(u  “.S  u.)  >0 

i 


It  follows  that  (7)  can  be  written  as 


8(u  - 


n-i 

u.) 
i-t  1 


n-i 

S  q(  1  -  u  +.S  u.) 

l**!  i 


r 


or 

s  ^  ^  ^  q<~  )  0.207  q 

u  ' 
n 

We  now  have 

TI\coron  5  !  Let  (C, ,  T,),  (C, ,  Tj),...(C„,  T„)  be  a  set  of  n  jobs  with 
u<  n(2*  '-1 ).  Let  T^!!  .  For  any  request  of  J^,  let  q  and  s  denote 

the  length  of  the  last  quantum  of  time  allocated  and  the  length  of  the 
slack  tine  of  any  request.  Then  s  a  0.207  q. 

PfooC  !  The  proof  of  the  Theoren  is  carried  out  by  induction  on  n. 

Lemma  3  provides  the  basis  of  induction.  As  to  the  induction  step  we 
consider  two  cases  : 

Case  I  ;  The  execution  of  the  last  quantum  of  time  allocated  to  the 
request  begins  at  no  more  than  units  of  tirac  after  the  arrival  of  the 
request  as  illustrated  in  Fig.  4(a). 


Let  C  denote  the  total  computation  time  allocated  to  within  the 


Since 


“rj  C  +  C 

u.  +  n 

1*1  i 


n-2 

X' 


.S  u.  + 


2C  ^  C 
n-i  +  n 


-ji - ..  -  fp  ip 

n  n  n 


(C  4  C^, 

V- 

n-2 

2C 

V  u. 

.  •>  1 
i«j 

X  n**! 

.f  mJL  < 

^  2T 

n-i 

»  M  * 

these  J'”!  jobs  are  scheJulable  by  the  rate  monotonic  scheduling  algorithm. 
Moreover,  Che  diagram  for  the  time  interval  I  rT^. 
shown  in  Fig.  4(b).  For  there  n-1  jobs,  since 
induction  hypothesis 

Since 

wo  have 


s'  a  0.207  q' 


«  s 


q'a  q 


$  2  0.207q 


Case  2  !  The  execution  of  the  last  quantum  of  time  allocated  to  the 
request  begins  at  later  than  units  of  time  after  the  arrival  of  the 
request.  The  derivation  of  the  bound  for  this  case  is  similar  to  case  2 
in  the  proof  of  Vnoorem  4,  and  will  not  be  repeated  here. 


5.  Remarks. 

Aside  £rora  the  results  in  Theorems  4  and  3  which  give  a  lower 
bound  of  the  slack  time  of  a  request  as  a  function  of  q,  it  seems  that 
slack  time  can  be  estimated  in  other  ways,  in  particular,  as  a  function 
of  the  utilization  factor  of  a  set  of  jobs.  Intuitively,  it  is  clear  that 
for  a  set  of  Jobs  with  a  small  utilization  factor,  the  slack  time  of  each 
request  should  become  large.  Our  result  only  uses  the  utilization  factor 
in  an  implicit  way. 

We  conjecture  chat  the  condition  in  Theorem  5 

is  unnecessary. 
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